Hnw dnps that 


Work? 


Error-correcting codes 

Many types of error-correcting techniques exist, but in data 

communications, Hamming encoding probably finds the 
widest use. Unlike serial-port communications that use a 
single parity bit, Hamming encoding adds many additional 
check bits to a transmission. Those bits take extra time to 
transmit, but the added overhead brings about more reliable 
communications. As used today, basic Hamming encoding 
will Let a receiver detect and correct a single-bit error and 
detect — but not correct — a two-bit error. Luckily, transmis- 
sion errors in packets of a few bytes usually involve only a 
single bit. (The theory behind Hamming codes goes beyond 
this discussion.) 

To find the number of Hamming check bits, k, you need 
to correct for a single error in a group of m bits, using the 
formula: 

m '£2k-k-l 

Thus, for a 16-bit word, five bits provide single-error correc- 
tion. By adding another bit, for a total of six, you'll obtain 
single-error correction and double-error detection. 

The eiaraple in the Hgure shows a 16-bit word and the 
bits in it used to compute six check bits. Simply sum the 
marked bits in each row to get the respective check bit. For 
example: 

CBo - Di3 + Dio + D, + Dg + D« + D, + Di + Do 
(An odd number of I's surris to 1, an even number of I's 


sums to 0.) Thus, calculating the checkbits as shown in Fig- 
ure 1, the data word (D^-Do) 0011 1101 1001 1001 yields 
check bits (CB5-CB0) 101100, which get transmitted with the 
16 data bits. 

How does the receiver use the check bits to locate an 
error? Assume the reception of data 0100 1101 0100 0111 
and check bits 010110. The receiver calculates a new set of 
check bits— 000000— based on the received data. In this 
example, the received check bits and the newly calculated 
check bits show differences at CB^, CBj, and CBj. The figure 
shows that only data bit Dj influences these three check 
bits, so that bit must be incorrect, or inverted. Thus, the ac- 
tual data should be 1011 1101 0110 0111. Each bit in the 
data word influences only three of the check bits, so a sin- 
gle-bit error will produce three incorrect check bits. 

In a communication system, hardware would compute new 
check bits and compare them with the received check bits. 
The comparator's output would address a simple look-up 
table that would identify the incorrect bit so the receiver 
could invert it. 

The check bits also yield other useful information. A sin- 
gle check-bit difference indicates an error in the check bits 
themselves. An even number of check-bit differences indi- 
cates two bit errors, which a receiver cannot correct. Three 
or more bit errors can fool some error-detecting and error- 
correcting systems. Thus, some errors will require a retrans- 
mission of data— Jon Titus 
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"How does that work?" is a bimonthly column covering test or measurement 
pRiduels tiiat take advantage of a novel effect or unusual technology. 
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